了252一夕三又产40

|章ハードカア実装 2025/2/23 最初にNANDドルのサからまえられる。 NANDゲーから各サートも実装していく。 NAND (No+And) JNot 7W0 out ٥. JAND OUT out

(Anol, Or, Not) 人りかりなる時にどり かななっ ハトからしい時にセシト は立たない。 Xor.hol ファイルのでも支を見て何ないてしまったので 表からif欠任Zhalzf在成けるようか。 気を多まになりそう Mux (2147017t) sel out if sel==0 out=a e se out = 0 ( a Op Sel) of (b And Sel) aprsel 20ut 6 And sel = out



DMux (frz11470l)fin→ EMux xt in, Sel it (Sel==0) Sel a b 出力 a, b {a,b}={in,o} 1 [4 0 N; O else {ab3 = {0.in3 X or And or NANd Sel outa= Xor (a=in,b=outb, out=a) ITOL: And (a=in, b=sel, out=outb, out=b); X of (a=in, b=outb, out = a); P. 388 & P.

Mux 4Way 16 Sel [1] Sel [0] out 4 may-Mux 0 b ď Sellin Sellon SelEJ Sel [0] out SelIIDがりでは a.b も出力, SelIIDが1のはは C,dを出力 Mux 16 (a=a,b=b, Sel=SelEO] out =outo); < SelEO] out Mux 16 (a=c, b=d, sel=selzo], out =out 1); ← Sel[]=1 Mux [b(a=outo, b=out), sel=se/[], out=out);

Mux 8 Way 16 Selen Selen Selton Mux 4 Way bb Muxlo

00 D Myx 4 Way [O ( \( \sigma \) Selen Selen 0000 1000 0 0 0 0000 001 0 0 0 0 Sel EID AVI ON YELL CID & DISTO STITULE OF. DMux ( in , sel = selso], a = out a, b = out b) j DMux (in=in, Sel=Seleo], a=outc b=out of); DMux (in=outa, Sel=Sel[], a= a, b= c); DMax (inzoutb, Sel=Sel[], a=b, b=d);

DMux 8Way Xp in, Sel [3] 生pla, b, c, d, e, f, g, h - Sel [2] Au On to e,f, g, h du o 12/13 · Sel [2] \$4 / n k & a, b, c, of \$401= t] }0 DMux 4Way (in=in, sel=se([0.1], a= a, b=b, C=c, d=d); DMux 4 Way (in=in, Sel=Sel [a.1], a=e, b=f, c=g, d=h); DMux (in=a, sel=SelIz], a=a, b=e); DMWX (TN-b, Sel=SelDJ, Q=b, b=f); bmux (in=C, Sel=Sel[], a=c,b=g); DM wx (zn = d, sel = Sel[2], a = d, b = h);

Xor (a=a,b=b, out=sum); AND(a=a,b=b,out=carry);



Half Adder (a= a 1 b=b 1 carry = ab carry, sum = ab sum);

HalfAdder(a=c, b=absum, carry=ccurry, sum=sum); Or (a=abcarry,b=ccarry,out=carry);

16时加算器 (Add16) 1 A TI6J, 6.[16] 2世小の場合 out [16] 10 a 11 a 11 + 6 01 + 6 11 out 110 out Toverflow (Xpt4)中裔主起文子) 1年刻 Half Adder ( a=a [o], b= b [o], carry = ocl, sum=outco] Full Adder (a=a[i], b=b[i], C=ocl, cally = ocz, sum=outin); これが外条の重し Q[0] =1, 6[0] =1, Qc[=1, out[0] =0 i=0 

16tunt 1271 XVI (Inc/6) >> In[16] 出力 6 MT C167 関数 out=n+1 ·/-nuxxblutstox01か以塞 -> +the P374 、 敬下位t"ル+1 は Xor で水められる→ Sum = OUT [i] の発り上げかり発生するかはANDでがあるれる。プCarry Xor(a=the,b=in四,out=on+con); ] 20台法で宴談すると (Xorx16) + (Andx15) And (a= incb=inco, out = carryo); の構成となる Xor(a=(ahyo,b=in[i],out=out[i]); And (az camyD,b=in[i], out = carry1); Add16.hd1を全り用 Carryo = Carryo And incol

carryo = inc And incol

in[0] Out[0] = inc Xor incol

in[1] 0 0 t/0 TMC OWTEN = Carpyoxor in[] カロ等器(funo (Add 16, holl) は |HalfAdderx1)+(FullAdderX15)では萬成される。 (Xorx1)+(Andx1)+(HalfAdderx2)+(Orx1) (Xorx3))+(Andx3)+Or (Xet + And)x2 Add 164ッでを利用すると(Xorx31)+(Avdx31)+Oトを手り用する。

等稅類理演算器(ALU) (xxxx, out, string) Zx.nx.zy,ny,f,no,out [ZX=1の時の X=0 And 16(a=false, b=X, out=X); NX=1の時のX=1X Not16(in=X,out=X); f=1 の時の out=x+y Add16(a=x,b=y.out=out); f=O n out= X &y And 16(a= X, b=y, out =out); ho=1の時の ont=!out Not16(?n=out, out=out); 分岐 出かを Mux nablo >>か、 Sel 12 多州(ZX,NX,f,no) もメカして出かすれば各件分岐による値の出かかってきる Not 16( in = 02x, out = not X); Addlb[az X, b=y, out = x addy); And  $16(a \times x, b = y, out = x and y)$ Mux(6(a= x , b= false, sel= zx, out = ozx); } y + au Mux(6(a= ozx, b=notx, sel= hx, out= onx); } Mux(6(a=xandy,b=xaddy,Se)=f,ovt=of);Not (6( in= of, out= not of); Muxlb (A=of (b=not of, Se)=no jout =out, outround =ono lows, ,8 April 2 - anohyp 8, Or 8 Way ( = 0 no. low 8 rout = 00+8 way /); out[15] = ng ); OF 8 Way (in = 0 No high8, out = 0 or 8 way 2); Or (120018my 1, 620018may 2, out = 001); Not (2n = oor, out = 2h);

フリーク0フロックの(DFF)は何身でり 2025/3/6 ~ XZY 候袋せずにせいしかを利用な (1ヒットレシッスタ) ti小(Bit)の実裝 出力 out Xt in, load 出力 out if load== | then out (ttl) = in(t) else out(t+1) = out(t) Mux (a=odff,b=in, sel=load, out=omux); DFF (in=oww, out =out, out = odff); lbtットレジスク (Register) か in [16], load In out[16] |ゼットレグスタも16何国内包(ている。 Bit (in >in Lo), load = load, out = outco); Bit (Ty = in [15], load = load, out = out [15]);

 $\fine {1000}$ ,  $\fine {1000}$ RAM8/ 4 Dut[16] RAMIO内包はなる 16 tinh レジリスタの数 address on 指定士本t=レジアク1=load 色渡す。DMUX8Way DMux & Way (in=load, sel=add ress, a=ola, b=olb c=olc, d=old, e= ole, f= olf, g= olg, h= olh); Register (in=in, load=0|a, out=orga); = 1 (load=01b, owt=01g1); 10ad=0/h, out=0/h7); Mux 8 Way 16 (A=orgo, b=orgl, c= org2, d= org3, e=org5, f= 0195, 9= org 6, h= org 7, sel = address, out=out);